using System;
using System.Data;
using System.Collections.Generic;

namespace SERP.DAO{
	/********************************BEGIN PersonTypesDAO****************************************/
	///<summary>
	/// <para>Author: Auto generated class by CSharp Code Generator v2.0</para>
	/// <para>Date:09/03/2013 19:09:04</para>
	/// <para>Class Name: PersonTypesDAO</para>
	/// <para>Description: Class access to table PersonTypes in database. Coder should'nt code here.</para>
	///</summary>

	
	public partial class PersonTypesDAO : DAOBase<PersonTypesEntity>{


		#region Select functions
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateSelectOneCommand</para>
		/// <para>Input: PersonTypeId</para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateSelectOneCommand(int PersonTypeId){
			string strSQL="SELECT  [PersonTypeId],[TypeName],[Note] FROM [PersonTypes]  WHERE [PersonTypes].[PersonTypeId]=@PersonTypeId";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			this.CreateCommandParameter(cmd,"@PersonTypeId",PersonTypeId);



			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: SelectOne</para>
		/// <para>Input: PersonTypeId</para>
		/// <para>Output: PersonTypesEntity</para>
		///</summary>
		public PersonTypesEntity SelectOne(int PersonTypeId){
			IDbCommand cmd=this.CreateSelectOneCommand(PersonTypeId);
			return this.Select(cmd);
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateSelectAllCommand</para>
		/// <para>Input: </para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateSelectAllCommand(){
			string strSQL="SELECT  [PersonTypeId],[TypeName],[Note] FROM [PersonTypes] ";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateSelectAllByKeyCommand</para>
		/// <para>Input: ColumnName,ColumnValue</para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateSelectAllByKeyCommand(string ColumnName,object Value){
			string strSQL="SELECT  [PersonTypeId],[TypeName],[Note] FROM [PersonTypes]  WHERE [PersonTypes].["+ColumnName+"]=@ColumnName";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			this.CreateCommandParameter(cmd,"@ColumnName",Value);



			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: SelectAll</para>
		/// <para>Input: </para>
		/// <para>Output: List of PersonTypesEntity</para>
		///</summary>
		public List<PersonTypesEntity> SelectAll(){
			IDbCommand cmd=this.CreateSelectAllCommand();
			return this.SelectList(cmd);
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: SelectAllDS</para>
		/// <para>Input: </para>
		/// <para>Output: DataSet</para>
		///</summary>
		public DataSet SelectAllDS(){
			IDbCommand cmd=this.CreateSelectAllCommand();
			return this.SelectDS(cmd);
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateSelectAllFilterCommand</para>
		/// <para>Input: </para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateSelectAllFilterCommand(string strFilter){
			string strSQL="SELECT  [PersonTypeId],[TypeName],[Note] FROM [PersonTypes]  WHERE "+RemoveInjection(strFilter);
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateSelectAllByKeyFilterCommand</para>
		/// <para>Input: ColumnName,ColumnValue</para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateSelectAllByKeyFilterCommand(string strFilter,string ColumnName,object Value){
			string strSQL="SELECT  [PersonTypeId],[TypeName],[Note] FROM [PersonTypes]  WHERE [PersonTypes].["+ColumnName+"]=@ColumnName AND "+RemoveInjection(strFilter);
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			this.CreateCommandParameter(cmd,"@ColumnName",Value);



			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: SelectAll</para>
		/// <para>Input: </para>
		/// <para>Output: List of PersonTypesEntity</para>
		///</summary>
		public List<PersonTypesEntity> SelectAllFilter(string strFilter){
			IDbCommand cmd=this.CreateSelectAllFilterCommand(strFilter);
			return this.SelectList(cmd);
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: SelectAllDSFilter</para>
		/// <para>Input: </para>
		/// <para>Output: DataSet</para>
		///</summary>
		public DataSet SelectAllDSFilter(string strFilter){
			IDbCommand cmd=this.CreateSelectAllFilterCommand(strFilter);
			return this.SelectDS(cmd);
		}
		#endregion

		#region Insert functions
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateInsertCommand</para>
		/// <para>Input: PersonTypesEntity</para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateInsertCommand(PersonTypesEntity o){
			string strSQL="INSERT INTO [PersonTypes]([PersonTypeId],[TypeName],[Note]) VALUES  (@PersonTypeId,@TypeName,@Note)";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			if(o.IsNullPersonTypeId)
				this.CreateCommandParameter(cmd,"@PersonTypeId",System.DBNull.Value);
			else
				this.CreateCommandParameter(cmd,"@PersonTypeId",o.PersonTypeId);

			if(o.IsNullTypeName)
				this.CreateCommandParameter(cmd,"@TypeName",System.DBNull.Value);
			else
				this.CreateCommandParameter(cmd,"@TypeName",o.TypeName);

			if(o.IsNullNote)
				this.CreateCommandParameter(cmd,"@Note",System.DBNull.Value);
			else
				this.CreateCommandParameter(cmd,"@Note",o.Note);


			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: Save</para>
		/// <para>Input: PersonTypesEntity</para>
		/// <para>Output: return true if succeeded else return false</para>
		///</summary>
		public bool Save(PersonTypesEntity o){
			IDbCommand cmd=this.CreateInsertCommand(o);
			bool result=false;
			result=this.ExcuteNoneQuery(cmd);
			cmd.Dispose();
			return result;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: SaveList</para>
		/// <para>Input: List of PersonTypesEntity</para>
		/// <para>Output: </para>
		///</summary>
		public void SaveList(List<PersonTypesEntity>list){
			foreach(PersonTypesEntity o in list){
				try{
					this.Save(o);
				}
				catch{
				}
			}
		}
		#endregion

		#region Update functions
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateUpdateCommand</para>
		/// <para>Input: PersonTypesEntity</para>
		/// <para>Output: </para>
		///</summary>
		protected IDbCommand CreateUpdateCommand(PersonTypesEntity o){
			string strSQL="UPDATE  [PersonTypes] SET [PersonTypes].[PersonTypeId]=@PersonTypeId,[PersonTypes].[TypeName]=@TypeName,[PersonTypes].[Note]=@Note WHERE [PersonTypes].[PersonTypeId]=@OldPersonTypeId";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			if(o.IsNullPersonTypeId)
				this.CreateCommandParameter(cmd,"@PersonTypeId",System.DBNull.Value);
			else
				this.CreateCommandParameter(cmd,"@PersonTypeId",o.PersonTypeId);

			if(o.IsNullTypeName)
				this.CreateCommandParameter(cmd,"@TypeName",System.DBNull.Value);
			else
				this.CreateCommandParameter(cmd,"@TypeName",o.TypeName);

			if(o.IsNullNote)
				this.CreateCommandParameter(cmd,"@Note",System.DBNull.Value);
			else
				this.CreateCommandParameter(cmd,"@Note",o.Note);

			if(o.IsNullOldPersonTypeId)
				this.CreateCommandParameter(cmd,"@OldPersonTypeId",System.DBNull.Value);
			else
				this.CreateCommandParameter(cmd,"@OldPersonTypeId",o.OldPersonTypeId);


			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateUpdateFieldCommand</para>
		/// <para>Input: ColumnName,ColumnValue,PersonTypeId</para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateUpdateFieldCommand(string ColumnName,object Value,int PersonTypeId){
			string strSQL="UPDATE  [PersonTypes] SET [PersonTypes].["+ColumnName+"]=@ColumnName WHERE [PersonTypes].[PersonTypeId]=@PersonTypeId";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			this.CreateCommandParameter(cmd,"@PersonTypeId",PersonTypeId);



			this.CreateCommandParameter(cmd,"@ColumnName",Value);


			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: Update</para>
		/// <para>Input: PersonTypesEntity</para>
		/// <para>Output: return true if succeeded else return false</para>
		///</summary>
		public bool Update(PersonTypesEntity o){
			IDbCommand cmd=this.CreateUpdateCommand(o);
			bool result=this.ExcuteNoneQuery(cmd);
			cmd.Dispose();
			return result;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: UpdateList</para>
		/// <para>Input: List of PersonTypesEntity</para>
		/// <para>Output: </para>
		///</summary>
		public void UpdateList(List<PersonTypesEntity>list){
			foreach(PersonTypesEntity o in list){
				try{
					this.Update(o);
				}
				catch{
				}
			}
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: UpdatePersonTypeId</para>
		/// <para>Input: NewPersonTypeId,PersonTypeId</para>
		/// <para>Output: return true if succeeded else return false</para>
		///</summary>
		public bool UpdatePersonTypeId(int NewPersonTypeId,int PersonTypeId){
			IDbCommand cmd=this.CreateUpdateFieldCommand("PersonTypeId",NewPersonTypeId,PersonTypeId);
			bool result=this.ExcuteNoneQuery(cmd);
			cmd.Dispose();
			return result;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: UpdateTypeName</para>
		/// <para>Input: NewTypeName,PersonTypeId</para>
		/// <para>Output: return true if succeeded else return false</para>
		///</summary>
		public bool UpdateTypeName(string NewTypeName,int PersonTypeId){
			IDbCommand cmd=this.CreateUpdateFieldCommand("TypeName",NewTypeName,PersonTypeId);
			bool result=this.ExcuteNoneQuery(cmd);
			cmd.Dispose();
			return result;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: UpdateNote</para>
		/// <para>Input: NewNote,PersonTypeId</para>
		/// <para>Output: return true if succeeded else return false</para>
		///</summary>
		public bool UpdateNote(string NewNote,int PersonTypeId){
			IDbCommand cmd=this.CreateUpdateFieldCommand("Note",NewNote,PersonTypeId);
			bool result=this.ExcuteNoneQuery(cmd);
			cmd.Dispose();
			return result;
		}
		#endregion

		#region Delete functions
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: DeleteAllCommand</para>
		/// <para>Input: </para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateDeleteAllCommand(){
			string strSQL="DELETE   FROM [PersonTypes]  ";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: DeleteCommand</para>
		/// <para>Input: PersonTypesEntity</para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateDeleteCommand(PersonTypesEntity o){
			string strSQL="DELETE   FROM [PersonTypes]   WHERE [PersonTypes].[PersonTypeId]=@PersonTypeId";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			if(o.IsNullPersonTypeId)
				this.CreateCommandParameter(cmd,"@PersonTypeId",System.DBNull.Value);
			else
				this.CreateCommandParameter(cmd,"@PersonTypeId",o.PersonTypeId);


			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: DeleteAll</para>
		/// <para>Input: </para>
		/// <para>Output: return true if succeeded else return false</para>
		///</summary>
		public bool DeleteAll(){
			IDbCommand cmd=this.CreateDeleteAllCommand();
			bool result=this.ExcuteNoneQuery(cmd);
			cmd.Dispose();
			return result;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateDeleteByPrimaryKeyCommand</para>
		/// <para>Input: PersonTypeId</para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateDeleteByPrimaryKeyCommand(int PersonTypeId){
			string strSQL="DELETE   FROM [PersonTypes]   WHERE [PersonTypes].[PersonTypeId]=@PersonTypeId";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			this.CreateCommandParameter(cmd,"@PersonTypeId",PersonTypeId);



			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: CreateDeleteByKeyCommand</para>
		/// <para>Input: ColumnName , ColumnValue</para>
		/// <para>Output: IDbCommand</para>
		///</summary>
		protected IDbCommand CreateDeleteByKeyCommand(string ColumnName,object Value){
			string strSQL="DELETE   FROM [PersonTypes]   WHERE [PersonTypes].["+ColumnName+"]=@ColumnName";
			IDbCommand cmd=this.CreateCommand(strSQL);
			cmd.CommandType=CommandType.Text;
			this.CreateCommandParameter(cmd,"@ColumnName",Value);



			return cmd;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: Delete</para>
		/// <para>Input: PersonTypesEntity</para>
		/// <para>Output: return true if succeeded else return false</para>
		///</summary>
		public bool Delete(PersonTypesEntity o){
			IDbCommand cmd=this.CreateDeleteCommand(o);
			bool result=this.ExcuteNoneQuery(cmd);
			cmd.Dispose();
			return result;
		}
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: DeleteByID</para>
		/// <para>Input: PersonTypeId</para>
		/// <para>Output: return true if succeeded else return false</para>
		///</summary>
		public bool DeleteByID(int PersonTypeId){
			IDbCommand cmd=this.CreateDeleteByPrimaryKeyCommand(PersonTypeId);
			bool result=this.ExcuteNoneQuery(cmd);
			cmd.Dispose();
			return result;
		}
		#endregion

		#region Select,delete by PersonTypeId functions
		#endregion

		#region MapObject functions
		///<summary>
		/// <para>Author: Auto generated by CSharp Code Generator v2.0</para>
		/// <para>Date:09/03/2013 19:09:04</para>
		/// <para>Name: MapObject</para>
		/// <para>Input: IDataReader</para>
		/// <para>Output: PersonTypesEntity</para>
		///</summary>
		protected override PersonTypesEntity MapObject(IDataReader r){
			PersonTypesEntity entity = new PersonTypesEntity();
			try{
				if(r.FieldCount>0){
					try
					{
						int ordinal = r.GetOrdinal("PersonTypeId");
						if (!r.IsDBNull(ordinal)) entity.PersonTypeId = ((int)(r.GetValue(ordinal)));
						entity.OldPersonTypeId=entity.PersonTypeId;
					}
					catch{}
					try
					{
						int ordinal = r.GetOrdinal("TypeName");
						if (!r.IsDBNull(ordinal)) entity.TypeName = ((string)(r.GetValue(ordinal)));
					}
					catch{}
					try
					{
						int ordinal = r.GetOrdinal("Note");
						if (!r.IsDBNull(ordinal)) entity.Note = ((string)(r.GetValue(ordinal)));
					}
					catch{}
					return entity;
				}
			}catch{}
			return null;
		}
		#endregion
	}
	/*****************************************************************************************************/
	/**********************************END PersonTypesDAOBase*****************************************/
	/*****************************************************************************************************/
}

